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(57) Abstract 

Transmission in a cell based switch of user cells which can include different numbers of data bits is synchronized. The transmission 
is performed via a two-way link between functional entities which each includes a link control function containing functions for starting 
and controlling transmission of data on the link by means of sync cells which are exchanged between the link control functions. The 
exchange of sync cells is controlled by a sync state machine having three states (304, 308, 312). In a HUNT state (312) the link control 
function investigates a sync cell coming in from the link for establishing whether it agrees with a predetermined pattern for sync cells. 
In a PRESYNC state (304), that starts after a sync ceil containing the predetermined pattern has been found in the HUNT state, the link 
control function investigates a predetermined number thereafter incoming consecutive sync cells for establishing whether they contain the 
predetermined pattern. If this is not the case the control process returns to the HUNT state, In a SYNC state (308), that starts after the 
predetermined number of sync cells containing the predetermined pattern has been found in the PRESYNC state, transmission of data on 
the link is admitted while supervising data with respect to faults. If faults are found the control process starts again in the HUNT state. 
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Synchronizing the t ransmission of data via a two-way link. 
Technical Field of the Invention. 

According to a first aspect the present invention relates to 
a method and a system for synchronizing, in a cell based switch, 
transmission of user cells which can include different numbers of 
5 data bits, between switch ports and switch core via a two-way 
link. 

According to a second aspect the invention relates to a 
system for synchronizing in a data transfer system the transmiss- 
ion of data in the form of a bit stream between functional 
10 entities via a two-way link, each functional entity having means 
for applying data arriving from users and intended for transmiss- 
ion on the link, in user cells which can include different 
numbers of data bits depending upon the size of the respective 
user data. 

15 m many data transmission systems different functional 

entities are connected together via a link. In particular this is 
the case in telecommunication systems. The link cost in many 
cases depends upon the number of physical interconnections. The 
more interconnections the higher the cost will be. It is 

20 therefore a usual practice to apply all information required on 
a single physical connection carrying a digital signal. This 
makes it necessary to reconstruct the logical structure" at the 
receiving end of the link. For performing this implicit in- 
formation must be transferred that points to the structure on 

25 different levels. 

Examples of implicit information which is coded in the 
digital signal is the clock that enables performing of bit 
alignment, and a synchronizing pattern which enables performing 
alignment on octets, words, ATM cells, or every other higher 

30 structure than bits. 
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Stand of the Art. 

Synchronizing in connection with transmission of ATM cells 
results in problems, in particular in case of different cell 
sizes appearing. 

5 A link for transferring ATM cells has a cell synchronizing 

mechanism based upon the so-called HEC Field (Header Error 
Correction Field) in the ATM cell and the process flow. A form of 
calculation denominated HCS (Header Check Sum) is based upon the 
four continuing octets and the remainder that is included in HEC. 

10 The process flow is based upon a state machine having states 
HUNT, PRESYNC and SYNC. A well known state machine for this 
purpose is described in the Bellcore document FA-NWT-001109 . 

A correct HCS calculation forces the state machine in 
question to a state PRESYNC. Provided that six consecutive 

15 correct HCS calculations appear in this state transition is 
performed to a state SYNC, otherwise transition is performed to 
a state HUNT. After seven consecutive incorrect HCS calculations 
in the state SYNC, transition is likewise performed to the state 
HUNT. 

20 An essential disadvantage with use of such a closed state 

machine that operates without support from the originating side 
is the time consumption for reaching the synchronizing state, and 
accordingly the cell loss when synchronization is lost. More than 
60 cells can be lost before the link is brought to an operative 

25 state. Another disadvantage is that the method in question does 
not admit transmission of cells of different sizes on the link. 

In the US patent 5,123,013 there is described cell synch- 
ronization in a packet connected system for sending and receiving 
a cell train composed of data cells of a fixed lenght including 

30 data to be .transmitted. At least one synchronizing cell contai- 
ning a synchronization pattern is inserted between the data 
cells. 

The synchronization cell or cells are transmitted in certain 
situations, viz. during a time period in which no data cell is 
35 transmitted, or after data cells have been transmitted successi- 
vely during a predetermined interval after the transmission of 
the synchronization cell. 
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GB 1,550,121 describes a speed tolerant digital data 
decoding system. Digital words are stored in cells of approxima- 
tely the same width, except for the initial cell of each word 
which is called sync cell and has the double width. 
5 DE 3,842,371 relates to an arrangement for clock synch- 

ronization of a cell structured digital signal. 

Summary of the Invention. 

An object of the invention is to provide a method for cell 
10 alignment in a bit stream that contains cells of different sizes. 
Generally, this is attained in accordance with the invention by 
using a fast synchronization algorithm based upon small synch- 
ronization cells and use of suitable devices on each side of a 
two-way link. 

15 In a method according to a first aspect the transmission of 

data on the link is started and supervised by means of sync cells 
which are exchanged between the functional entities and each 
contains, on the one hand a synchronizing pattern, by means of 
which the sync cell can be identified, and, on the other hand, 

20 control data. By the functional entitites control data can be set 
to values admitting mutual checking that synchronism prevails, or 
a value that in a state of operation on the link, that is 
apprehended as implying loss of synchronism, forces the func- 
tional entities to take measures for reinstating synchronism. 

25 In a system according to the first aspect a link control 

function is included in each functional entity containing 
functions for starting and controlling the transmission of data 
on the link by means of sync cells which are exchanged between 
the link control functions controlled by a sync state machine 

3 0 that has three states. In a HUNT state the link control function 
is brought to investigate a sync cell coming in from the link for 
determining whether it agrees to a predetermined pattern for sync 
cells. In a PRESYNC state, preceded by a sync cell being in 
agreement with the predetermined pattern having been found in the 

3 5 HUNT state, the link control function is brought to investigate 
a predetermined number of consecutive sync cells coming in 
thereafter for determining whether they agree to the predeter- 
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mined pattern. Return to the HUNT state is performed if this is 
not the case. In a SYNC state, preceded by the predetermined 
number of sync cells having shown agreement with the predeter- 
mined pattern in the PRESYNC state, transfer of data on the link 
5 is admitted while supervising data with respect to errors. 
Transition to the HUNT state is performed if an error is found. 

In a system according to a second aspect a link control 
function is included in each functional entity with functions for 
starting and controlling the transfer of data on the link by 

10 means of sync cells, which are exchanged between the link control 
functions and each include, on the one hand, identification 
information, by means of which the sync cell can be identified 
and, on the other hand, control data. By each link control 
function the control data can be given values which admit mutual 

15 check that synchronism exists, or a value which in an operational 
state on the link apprehended as meaning loss of synchronism, 
forces the two link control functions to take measures to re- 
instate synchronism. An output function towards the link has a 
sync cell inserting function that receives a stream of user cells 

2 0 and in this inserts sync cells, and a first transforming function 

that receives the resulting stream consisting of user cells and 
sync cells and transforms this to a bit stream signal, that is 
clocked with a 1-bit clock signal out onto the link. An input 
function from the link comprises a second transforming function 
25 that receives a bit stream signal coming in from the link and 
transforms this to an n-bit parallel format, that is normally 
clocked out for each n:th bit with an n-bit clock signal from the 
input function. A comparison function is connected for searching 
and identifying in the n-bit parallel format the identification 

3 0 information of a sync cell, and when it is found emit a con- 

firmation signal. A clocking function enables clocking out for 
each bit with a 1-bit clock signal of the n-bit parallel format 
from the input function. A sync state machine receives the 
confirmation signal for controlling the transition from clocking 
35 of the n-bit parallel format with the n-bit clock signal to 
clocking with the 1-bit clock signal. 

Important advantages of the invention are the fast synch- 
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ronization and that it allows appearance of different cell sizes. 
Description of the Drawings. 

The invention will now be described more closely below with 
5 reference to the attached drawings on which 

Fig. 1 schematically shows a telecommunication switch 
intended for both ATM and STM line connections, in which the 
invention can be used. 

Pig. 2 more in detail and on a larger scale shows a part of 
10 the switch according to Fig. 1, including a two-way transmission 
link between a switch port and the switch core, for illustrating 
some main aspects of the inventive idea, 

Fig. 3 shows a sync state diagram for a sync state machine 
used in connection with cell synchronization performed in 
15 accordance with the invention on the transmission link according 
to Fig. 2, 

Fig. 4 shows a transaction state diagram between a switch 
port and switch core while using the sync state machine according 
to Fig. 3 for a possible practical synchronization scenario, 
20 Figs. 5 and 6 show examples of embodiments of a synch- 

ronization cell and a user cell, respectively, 

Fig. 7 in some detail shows a functional diagram of an 
embodiment of a link control system according to the invention as 
included in each switch port and switch core, according to Fig. 
25 3, 

Fig. S shows a functional diagram of a part of the link 
control system according to Fig. 7 more in detail, 

Fig. 9 shows a simplified sync state diagram for a sync 
state machine used in connection with performing cell synch - 
3 0 ronization in accordance with the invention, 

Fig. 10 shows a transaction state diagram between a switch 
port and switch core when using the sync state machine according 
to Fig. 9 for a possible practical synchronization scenario, 

Fig. 11 shows a more detailed sync state digram for a sync 
35 state machine used in an embodiment of a link control system 
according to the invention as described with reference to the 
following Figures, 



WO 96/42158 PCT/SE96/00773 
6 

Fig. 12 shows a functional digram of a link control function 
in which the sync state machine according to Fig. 11 is included, 

Figs. 13 and 14 show time control diagrams of examples of 
link synchronization processes in the link control system 
5 according to Fig. 13. 

Preferred Embodiments. 

Fig. 1 shows a cell based telecommunication switch intended 
for both ATM (Asynchronous Transfer Mode) and STM (Synchronous 

10 Transfer Mode) line connections. The switch includes a plurality 
of switch ports 102 ^102,, connected to a switch core 104 via each 
a two-way link 106J-106JJ. The switch ports 102 are connected to 
e.g. a communication network that can contain e.g. incoming lines 
107 and 108, processors etc. The lines 107 and 108 can carry ATM 

15 cells or STM time slots. The switch ports 102 ( and 102 2 are shown 
schematically as an example to be located on a line interface 
circuit card 110, for STM line connection and a line interface 
circuit card 110 2 for ATM line connection, respectively. The line 
interface circuit cards llOj and 110 2 are also shown schematically 

20 as containing each a respective line termination 112j and 112 2 
which via a respective link 114 1 and 114 2 for user data is 
connected with the corresponding switch port 102 1 and 102 2 , 
respectively. The switch port I02 n is schematically shown as an 
example to be located on a server card H0 n which includes a 

25 processor 116 connected to the switch port via the link 114 for 
user data. 

Fig. 2 illustrates the two-way traffic between e.g. the 
switch port 102 n and the switch core 104 via the link 106 n more 
in detail. The switch port 102 n applies arriving user data in 

30 user cells. The size of these user cells is chosen so as to suit 
the user data. For an ATM cell of 53 octets a user cell size of 
56 octets can thus be chosen, i.e. 53 bytes plus cell size in- 
formation plus checksums. STM time slots are applied in smaller 
cells. The user cell is then guided from a switch port to another 

3 5 one through the switch core. For a more detailed description of 
the technique of applying user data in user cells, and different 
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circumstances in this context reference is made to Swedish patent 
application No. 9402051-8. 

The switch port I02 n contains a link control function 202 
that receives user cells based upon user data arriving from the 
5 outside to be forwarded on the link 106 n , and emits user cells 
arriving from the link, the data of which shall be sent out on 
e.g. the network, indicated by double arrow 204. The traffic 
between the switch port 102 n and the switch core 104 proceeds 
between the link control function 202 and a link control function 
10 206 in the switch core. The link control functions 202 and 206 
manage the cell synchronization, as will be. described more 
closely below. 

Cells of different sizes are transmitted on the link as a 
bit stream in both directions, said bit streams being schemati- 
15 cally indicated at 208 and 210. In the bit streams 208 and 210 
user cells are indicated at 212 and 214, respectively. No 
explicit information regarding the beginning of a cell is 
transferred. Both sides must therefore perform cell alignment for 
synchronizing the link. For this purpose sync cells are used 

2 0 which at need are introduced into the user cell flow. In the bit 

streams 208 and 210 a sync cell is indicated at 216 and 218, 
respectively, as an example. The sync cells are originated and 
terminated in the link control function 202 and 206, respectively 
on each side, i.e. they do not appear in the switch ports or the 
25 switch core outside the link control functions. The user cells 
are guided unaffected through the link control functions. The 
execution and way of operation of the link control functions will 
appear more in detail from the following description of embodi- 
ments . 

3 0 Fig. 3 shows a sync state diagram illustrating the way of 

operation of a state machine for the link control functions on 
each side of the link, which is used for synchronizing the link. 
Sync cells coming from the link to a link control function are 
compared with a predetermined pattern for sync cells. A first 
3 5 detected agreement between an incoming sync cell and the 
predetermined pattern forces the state machine according to arrow 
302 to a state 3 04 PRESYNC. Provided that thereafter two 
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consecutive sync cells in the state PRESYNC are found, which show 
agreement with the predetermined pattern, transition is perfor- 
med, arrow 306, to a state 308 SYNC, otherwise transition is 
performed, arrow 310, to a state 312 HUNT. The method according 
5 to the invention is based upon the consecutive transmission of 
sync cells during the PRESYNC state. In the SYNC state user cells 
can be transmitted. Each user cell must include information 
enabling maintenance of the cell synchronization, and furthermore 
have error codes making it possible to detect an error in the 

10 cell size. A detected error in the SYNC state 3 08 forces likewise 
the state machine to the state 312 according to the arrow 314. To 
secure a true SYNC state if the error codes in the user cells 
cannot be considered enough, also a supervision state machine can 
be added to the SYNC state. This supervision function forces the 

15 state machine to the state 312 according to the arrow 314 if a 
predetermined number n of consecutive user cells appear. For 
further elucidation in connection with that mentioned above 
regarding the construction and desirable properties of user 
cells, reference is made to the above mentioned Swedish patent 

20 application 9402051-8. 

To attain fast synchronization and for keeping the link in 
an operative state it is required that the link control unit on 
the side that receives user cells can transmit control data in 
the sync cells on the link to the link control function on the 

25 originating side. 

Examples of such control data (commands) and measures caused 
thereby that can then appear in the link control unit on the 
originating side are: 

1. Control data: abort. Implies instruction to the origina- 
3 0 ting link control unit to stop the current transmission of user 

cells and instead send a sync cell. The current transmission of 
sync cells shall be completed and the new sync cell be inserted 
thereafter. 

2. Control data: prompt. Indicates that SYNC state is 
35 present and implies instruction to the originating link control 

unit to return a sync cell at the first suitable point of time. 
More particularly, the returned sync cell shall be introduced 
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into the normal cell flow so as to involve as little disturbance 
as possible in normal operation. 

3. Control data: sync. Indicates that no sync cell is 
required in return from the originating side. 
5 The use of the above three control data or commands will 

appear more closely below from the description with reference to 
Figs. 5, 7 and 8. 

The abort command could be replaced by the prompt command as 
will appear below i.a. in connection with the description with 
10 reference to Fig. 5. The result will be a somewhat slower 
synchronization if a great user cell is transferred at this point 
of time. 

The following sync cell transition rules are applied for the 
state machine: 

15 1. HUNT / PRES YNC state. Send sync cells to the originating 

side containing abort or prompt command. The sync cell should be 
sent at the first suitable point of time without stopping a 
current cell transmission. 

2. SYNC state. Send user cells, or send sync cells if a sync 

2 0 cell with abort or prompt command has been received. If sync 

cells are returned they should normally contain the control data 
sync. 

Fig. 4 schematically shows a simple transaction state 
diagram between switch port 402 and switch core 404 for a 
25 possible synchronization scenario. 

At first, both sides are in either of the states HUNT and 
PRESYNC. Accordingly they are sending sync cells with control 
data prompt/abort, arrows 406 and 408, respectively. After a 
defined number of consecutive sync cells both enter the SYNC 

3 0 state. In the shown example, the switch core side 4 04 passes into 

the SYNC state according to arrow 410 before the switch port. The 
switch core therefore responds to the sync cells with control 
data abort/ prompt by sending a sync cell with the control data 
sync, arrow 412. The switch port 402 now passes into the sync 
35 state, arrow 414. The switch port knows that the switch core is 
already in the SYNC state and therefore allows transmission of 
user cells, arrow 416. The switch core 404, now receiving user 
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cells, can in turn admit transmission of user cells, arrow 418. 
The link is now in an operative state on both sides and will 
remain such until either side enters the HUNT state due to the 
detection of an error or the supervising function coming into 
5 operation. 

In this example the switch port 4 02 is affected and passes 
into the HUNT state according to arrow 42 0. The switch port now 
sends out sync cells with control data abort/prompt according to 
arrow 422. The switch core 404 must respond by sending sync cells 

.0 containing the control data SYNC instead of user cells according 
to arrow 424. After the required number of consecutive sync cells 
the switch port resumes the SYNC state, arrow 42 6. 

The two sides can check each other in normal operation with 
respect to they being really in the SYNC state. This can be done 

5 by regularly sending sync cells with the control data prompt. The 
other side should respond within a predetermined time with a sync 
cell with the control data sync. If this does not occur, it can 
be assumed that it is in some kind of erroneous SYNC state. The 
synchronization can e.g. be lost but this is not detected due to 

0 the presence of a correct pattern in user cells in the locations 
where cell analysis is performed and this state can prevail 
during a longer period of time. The correct measure if no sync 
cell appears in return is to stop the sending of user cells and 
force the other side to synchronization. The described method can 
complete or replace the earlier described supervision function. 

A first embodiment of a link control system according to the 
invention shall now be described more in detail with reference to 
Figs. 5-8. 

To provide fast synchronization the sync cell should 
suitably be. as small as possible and still as big as to allow a 
pattern which is improbable to find in the user cells during an 
uninterrupted period of time. Fig. 5 shows an example of 
realization of the sync cell. The size of the sync cell is 
restricted to two words 502 and 504. All codes are given in 
tetrabinary form. The first word 502 contains a sync pattern hex 
C2F1. The second word 504 contains a control data field for 
control data sync and prompt, the latter in this case having 
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replaced abort, a possibility mentioned as an alternative above. 
According to the main alternative the control data field 504 in 
Fig. 5 could thus, besides the two control data sync and prompt 
shown, also include control data abort. In Fig. 5 the codes hex 
5 0100 and hex 0200 are indicated as an example for sync and 
prompt, respectively. 

The transmission direction is bit 1 to 16 and word 1 to 2 . 
The most significant bit in a field is transmitted first. The 
rightmost bit is least significant. The stated synchronization 

10 pattern is only an example; other codes can also be used. The 
synchronization pattern together with the control codes is chosen 
so as to enable unambiguous definition of the starting position 
of the sync cell in a consecutive sequence of sync cells. The 
control codes are chosen with a Hamming distance of two. Other 

15 codes are conceivable. 

Fig. 6 shows the user cell as containing a number of words 
602j - 602 n . The size field 604 contains codes for different 
determined sizes with redundant coding that admits error 
detection. The method is well known and can be based on Hamming 

20 code or similar. The user cell also contains two parity bits 606 
and 608. Further details can be fetched from the above mentioned 
Swedish patent application 9402051-8. A code similar to that of 
the sync cell is not allowed. If an error appears in the size 
field or the parity bits the state machine according to Fig. 3 

25 enters the HUNT state 312. 

Fig. 7 shows a function block diagram for a link control 
function of the type that superficially has been described 
earlier with reference to Fig. 2 and that is included in each 
switch port and in the switch core. As is the case for Fig. 2 the 

30 designation 206 is used in Fig. 7 for the link between the two 
link control functions, and the designation 204 for the stream of 
user cells to and from the link control function. In Fig. 7 a 
partition has however been made so that the stream of user cells 
from the link control function is designated 2 04 f and the stream 

35 of user cells to the link control function is designated 204 t . The 
link control function includes a series/parallel converting and 
sync cell aligning function 702, a cell analysing function 704, 
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a sync state machine 706, a sync cell aligning function 70S, a 
clock generator 710 and a parallel/series converter 712. The 
function of the sync state machine 706 can be conceived to be 
according to Fig. 4. 
5 On the link 106 between a switch port and the switch core a 

bit stream signal and a bit clock signal are transferred in each 
direction, indicated by arrows 716 and 718 for the receiving 
direction and arrows 720 and 722 for the sending direction, 
respectively. S/P converter and sync cell alignment function 702 
10 receives the bit stream 716 and converts it to 16 bits parallel 
data that is admitted as a word stream 72 4 to the cell analysing 
function 704 . 

Always when the state HUNT is true for the sync state 
machine 706 it emits a hunt signal 72 6 to the S/P converter and 

15 sync cell alignment function 702 that forces the later to hunt a 
sync cell pattern for each bit position, cf. Fig. 5. When this 
pattern has been found the function 702 emits a sync agreement 
signal 728 to the sync state machine 706 and a sync start signal 
730 to the cell analysing function 704. The sync agreement signal 

20 728 forces the sync state machine 7 06 to the state PRESYNC and 
deactivates the hunt signal 726. The sync start signal 730 that 
is only active when the hunt signal 726 is active, indicates to 
the cell analysing function 704 that a sync cell has been found. 
The S/P converter and sync cell alignment function 702 now 

25 passes to a parallel mode and clocks the incoming bit stream 716 
word by word. Each word is indicated by a word clock signal 732 
to the cell analysing function 704. The S/P converter and sync 
cell alignment function 702 emits the sync agreement signal 728 
to the sync state machine each time it identifies a sync pattern. 

30 The cell analysing function 704 contains an internal cell 

size counter, not shown, that it starts when it receives the sync 
start signal 730. The counter is clocked by the word clock signal 
732. When the cell size has been counted down the cell analysing 
function 704 emits to the sync state machine 706 a new cell 

35 signal 734 that indicates that a new cell is expected. The cell 
analysing function 704 studies the new cell to see if it has an 
accepted format in the size field. A non accepted code results in 
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transmission of an error signal 73 6 to the sync state machine 
706. The error signal 736 forces the sync state machine 706 to 
the state HUNT. 

The cell analysing function 704 passes on, the arrow 204 f , 
5 the found user cells for further treatment in the switch port and 
the switch core, respectively. A sync cell is terminated in the 
cell analysing function 704. The control data of the sync cell is 
taken out and if a prompt is indicated, cf . the earlier descrip- 
tion with reference to Figs. 3 and 5, a prompt signal 740 is sent 
10 to the sync cell inserting function 708. An unknown control code 
results in transmission of the error signal 736 to the sync state 
machine 7 06. 

The function flow of the sync state machine 7 06 appears from 
the state diagram according to Fig. 3. The following rules are 

15 valid: if the sync agreement signal 728 appears in the state HUNT 
it will be forced to the state PRESYNC. The new cell signal 734 
together with the sync agreement signal 72 8 forces it to the 
state SYNC after two consecutive sync cells. If a supervision 
function is used it will be reset by each new cell signal 734 

20 together with the sync agreement signal 728. Trigging the 
supervision function forces the sync state machine to the state 
HUNT. The sync state machine 706 emits the hunt signal 726 to the 
S/P converter and sync cell alignment function 7 02 always when it 
is in the state HUNT, and a sync signal 742 to the sync cell 

25 inserting function 708 always when it is in the state SYNC. 

The sync cell inserting function 708 uses the sync signal 
742 to generate, in a control code generator 744, the control 
code in the outgoing sync cells and for emitting compulsory sync 
cells 746 to a sync cell/user cell switch function 748 when the 

3 0 sync signal is deactivated (indicating the state HUNT or 
PRESYNC) . In the switch function 748 a sync cell 746 is in- 
troduced in a stream 750 of user cells when the prompt signal 740 
appears. The cell stream 750 originates from a fifo 752 in which 
user cells coming in according to the error 2 04 t to the sync cell 

35 inserting function 708, are stopped when a sync cell is inserted 
in the switch function 748. The sync cell inserting function 708 
uses the clock from the clock generator 710 for operating its 
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logic, arrow 756. 

The P/S converter 712 receives data in word format, arrow 
758, and creates a serial bit stream forming the outgoing bit 
stream 722 for transmission on the link 206 to the switch port 
5 and switch core, respectively, with a speed determined, arrow 
760, by the clock generator 710. 

The clock generator 710 sets the bit clock and clocks the 
bit stream blocks 722 in the outgoing direction. The clock 
generator 710 could use the incoming bit clock signal 718 for 

10 attaining the same speed in both directions, as indicated with a 
dashed line 762. In this case the other side must be a clock 
master and generate the clock whereas the side using the incoming 
bit clock signal 718 for clocking the outgoing bit stream 722 is 
a slave. In such case the slave need not send the clock signal 

15 72 0 further on the link 106. 

Fig. 8 shows the S/P converting and sync cell aligning 
function 702 more in detail. More particularly, it is shown as 
divided into a series/parallel converter 802 and a sync cell 
aligning function 804, internal logic being elucidated. 

20 The series/parallel converter 802 contains a 16 bit shift 

register 806 and a 16 bit register 808. Controlled by the bit 
clock signal 818 the 16 bit shift register 8 06 converts the 
incoming bit stream to a 16 bit parallel format 810. As will 
appear more closely below the 16 bit register is normally clocked 

25 by an aligning clock signal 812 for each 16th bit clock pulse for 
completing the series/parallel convertion, and for each bit clock 
pulse during the search for the sync pattern. 

The sync cell aligning function 804 contains a comparison 
function 813, a bit clock divider 814 executed as a 4 bit 

30 counter, a. multiplexor 816 with some combinatory logic. The 
comparison function 813 is connected to the output of the 
register 808 for sensing, arrow 818, when the hexadecimal pattern 
C2F1 appears in the word stream 724. When this is the case the 
comparison function 813 emits the sync agreement signal 728, 

3 5 below also denominated equal signal, to the sync state machine 
706, cf. Fig. 7. The sync agreement signal 728 multiplied with 
the hunt signal 72 6 forms the sync start signal 730. This is 
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symbolized with an AND function 820, the two inputs of which are 
connected for receving the sync agreement signal 728 and the hunt 
signal 726, respectively, and on the output of which the sync 
start signal 730 is emitted when both the sync agreement signal 
5 and hunt signal appear. 

The inverted sync agreement signal 728 multiplied with the 
hunt signal 726 controls the multiplexor 816. This is symbolized 
with an AND function 822 with an input connected for receiving 
the hunt signal 72 6 and an inverting input connected for 

10 receiving the sync agreement signal 728. The output 824 of the 
AND function 822 is connected for controlling the multiplexor 
816. The multiplexor 816 is connected for receiving the bit clock 
signal 718 and an output signal 828 on the output of an AND gate 
829, the inputs of which receive each one of the four bits 

15 appearing on the output of the counter 814. When the hunt signal 
726 but not the sync agreement signal 728 appears, i.e. the 
output of the AND function 822 gets high, the bit clock signal 
718 is chosen by the multiplexor 816 as alignment clock signal on 
the clock input 812 of the register 808. When both the hunt 

2 0 signal 726 and the sync agreement signal 7 28 appear, i.e. the 
output of the AND function 822 becomes low, the signal 828 
derived from the bit clock divider 814 is chosen as an alignment 
clock signal. This derived clock signal is active each 16th of 
the time. 

25 The 4 bit counter of the bit clock clock divider 814 counts 

up one step for each bit clock pulse. The bits appearing on the 
four outputs of the bit clock divider 814 are indicated bO, bl, 
b2 and b3 . The most significant bit b3 is used as the word clock 
signal 732. The bit clock divider 814 has a reset input 832 

30 connected to the output 824 of the AND function 822. The bit 
clock divider is reset when the output 824 goes high due to lack 
of the signal sync agreement 728 on the inverting input of the 
AND function 822, i.e. when the bit clock signal 718 is chosen as 
an alignment clock signal, when the sync pattern is found, i.e. 

35 the output 824 goes low due to the sync agreement signal 72 8 
appearing on the inverting input of the AND function 822 the bit 
clock divider 832 starts counting, with restart after 16 steps. 
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A further example of a state machine and a transaction 
transition diagram between switch port and switch core for a 
possible synchronizing and resynchronizing scenario according to 
this state machine will now be described more closely with 
5 reference to Figs. 9 and 10. 

In the current example states and corresponding codes stated 
below will be transferred and on the receiving side result in the 
simultaneously stated measures: 

1 - SYNC. Indicates to the receiving side that the origina- 
10 ting side is in a SYNC state. 

2 - PRESYNC. Informs the receiving side that the originating 
side is in PRESYNC state and desires a synchronizing cell in 
return at the first suitable point of time. The returned 
synchronizing cell shall be introduced in the normal cell stream 

15 so as to cause as little disturbance as possible of normal 
operation . 

Pig, 9 shows the sync state diagram for one side. 
The incoming synchronizing cells from the opposite side of 
the link are compared to the predetermined pattern for synch- 

20 ronizing cells. In the PRESYNC state 902 and after three 
consecutive synchronizing cells the SYNC state 906 appears 
according to arrow 904. In the SYNC state 906 user cells can 
start flowing. The user cell contains information with respect to 
its size, which is used for maintaining cell synchronization in 

25 the SYNC state. A detected error in the user cells directly 
forces the sync state machine to the PRESYNC state 902 according 
to arrow 908. 

To attain fast synchronization and keep the link in an 
operative state it is required that the state of the opposite 
3 0 side can be transmitted in the synchronizing cells. The states 
are given in the synchronizing cell specification. 

The following synchronizing cell transition rules are valid 
for the sync state machine: 

1 - In the PRESYNC state. Send synchronizing cells to the 
35 opposite side with an indication regarding PRESYNC state. The 
switch core shall end a current transmission of user cells 
towards the switch port. The switch port is allowed to break or 
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end a current transmission towards the switch core. 

2 - In the SYNC state. Allow transmission of user cells. 
Received synchronizing cells indicating PRESYNC state shall 
result in a corresponding synchronizing cell after the current 

5 transmission of user cells has been completed. 

3 - Consecutive synchronizing cells indicating PRESYNC state 
shall correspond to a consecutive stream of synchronizing cells 
after the allowed initiating delay caused by a current transmiss- 
ion of a user cell. 

10 4 - The switch port shall send synchronizing cells, which 

simulate the state PRESYNC, on a regular basis for verifying, in 
the state SYNC, that the switch core is in a true sync state. 

In Fig. 10 both sides are first in the PRESYNC state. 
Accordingly they send synchronizing cells, generally indicated 

15 1002, with the state PRESYNC. After the defined number of 
consecutive synchronizing cells both sides enter the SYNC state, 
which appears at different points of time. In the example shown 
in the Figure the switch core 1004 first enters the SYNC state, 
arrow 1006, before the switch port 1008. The switch core 1004 

20 therefore responds to its three received synchronizing cells 
indicating the state PRESYNC, by sending, arrow 1010, a synch- 
ronizing cell indicating the state SYNC for each received 
synchronizing cell indicating the state PRESYNC. After at least 
three consecutive synchronizing cells 1002, which have been 

25 emitted by the switch core 1004, the switch port 1008 enters the 
SYNC state, arrow 1012. The switch port 1008 now starts sending 
user cells, arrow 1014, since no synchronizing cells with the 
state PRESYNC arrive from the switch core 1004. The switch core 
1004 now receiving user cells can in turn admit sending of user 

30 cells, arrow 1016. The link is now in operation on both sides and 
will remain so until either side enters the PRESYNC state due to 
some detected error. 

In this example the switch port 1008 detects an error in a 
received user cell, arrow 1018, and enters, arrow 1020, the 

35 PRESYNC state. The switch port 1008 now sends synchronizing cells 
with the state PRESYNC, arrow 1022, The switch core 1004 must now 
respond, arrow 1024, by sending synchronizing cells indicating 
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the state SYNC, arrow 1026, instead of user cells. After the 
required number of synchronizing cells the switch port 1008 
resumes the SYNC state, arrow 1028. Thereafter both sides return 
to sending user cells to each other, arrow 1030. 
5 corresponding courses when the switch core 1004 detects an 

error in a received user cell, arrow 1032, is also indicated. It 
enters, arrow 1034, the PRESYNC state and sends synchronizing 
cells indicating the state PRESYNC, arrow 1036. The switch port 
1008 must now respond, arrow 1038, by sending synchronizing cells 

10 indicating the state SYNC, arrow 1040, instead of user cells. 
After the required number of synchronizing cells, the switch core 
1004 resumes, arrow 1042, the synchronizing state. Thereafter 
both sides revert to sending user cells to each other according 
to double arrow 1044 . 

15 Theoretically there is a small probability that the switch 

core enters a false SYNC state. This implies that the synch- 
ronization is lost, but is not detected. The reason can be a 
correct synchronizing pattern in the user cells or an erroneous 
user cell head. This situation could theoretically extend over a 

2 0 long period of time. For handling such a situation the switch 

port side 1008 during normal operation can check that the switch 
core 1004 is really in the SYNC state by regularly emitting a 
synchronizing cell, arrow 104 6, simulating the state PRESYNC. 
Within a predetermined period of time, after the current user 

25 cell transmission, the switch core 1004 shall respond, arrow 
1048, with a synchronizing cell with the state SYNC, arrow 1050. 
If this not occurs it can be assumed that the switch core is in 
some kind of false SYNC state. 

If no synchronizing cell is returned the sending of user 

30 cells is ended and the switch port side is forced into synch- 
ronism. 

In normal operation the switch port can also secure that its 
own terminating side is in a real SYNC state by quite simply 
keeping the synchronizing cells in the simulated state PRESYNC 

3 5 during a time period corresponding at least to the longest user 

cell type. 

With reference to Figs. 11-14 a more detailed description 
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will now be provided of a modification of a part of the link 
control function according to Figs. 7 and 8. The following 
properties and measures are i.a. in common with the earlier 
embodiment. An incoming serial bit stream shall be synchronized, 
5 the serial data being converted to 16 bit parallel data, and 
during the alignment of the synchronizing process alignment is 
performed of data to correct cell limits. The incoming clock 
speed shall be divided down to the clock speed of the clock 
signal (signals) used in the switch core. In the outgoing 

10 direction, towards the switch port, the outgoing 16 bit parallel 
data are converted to a serial bit stream. 

In Fig. 12 the same or corresponding parts as in Fig. 7 and 
8 have been given the same reference designations. 

As will appear the embodiment according to Figs. 11-14 is 

15 based upon the understanding that the fastest possible cell 
synchronization while using the smallest possible amount of chip- 
area can be attained by using only a 16 bit comparator 813 and 
make synchronization pattern comparisons each clock cycle. The 
comparator 813 compares 16 bit data from the series/parallel 

20 converter 808 with the pattern that shall be included in the 
first 16 bits of the synchronization cell. The synchronization 
state machine 706 keeps track, referring to Fig. 11, of the 
current one of four synchronization states, viz. HUNT 1102, first 
PRESYNC 1104, second PRESYNC 1106 and SYNC 1108. 

25 In the HUNT state 1102 the link synchronization process is 

active, when the comparator 813 indicates a pattern similarity 
the process enters the first PRESYNC state 1104, arrow 1110. 
After three consecutive pattern similarities, arrows 1112 and 
1114, the SYNC state 1108 and normal operation can start. 

30 In the states SYNC 1108 and PRESYNC 1104/1106 the output 

register 808 in the series/parallel converter 802 is loaded only 
once for each 16th data bit cycle, so as to provide a complete 
new 16 bit word after each 16th data bit. During the synch- 
ronization process the register 808 shall however instead be 

35 clocked each clock cycle (by the data clock 718 from the switch 
port) . As a result the bits in the incoming series data stream 
716 are shifted two bit positions for each data clock cycle (two 
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bits due to data from the switch port changing on both clock 
edges) , with a new bit in bit position 0 and bit position l, 
respectively. During each clock cycle the comparator 813 scans 
the outgoing word stream for the synchronizing pattern. At 
5 pattern similarity the signal 728 is emitted that starts normal 
operation of the synchronizing unit. This implies that the 
register 808 is stopped from being loaded each clock cycle, a 
transition to the first PRESYNC state 1104 is performed according 
to the arrow 1110, and the clock divider 814 which has been reset 

10 during the link synchronization process starts counting from 0 up 
to 15. If also the next cell is a synchronizing cell the second 
PRESYNC state 1106 is attained according to the arrow 1112, 
otherwise return is performed to the HUNT state 1102 according to 
arrow 1116 and the link synchronization process restarts. After 

15 three consecutive synchronization pattern similarities the 
process enters the state SYNC 1108, arrow 1114, otherwise return 
is performed to the HUNT state 1102 according to arrow 1118 and 
the link synchronization restarts. Return to the HUNT state 1102 
from the SYNC state 1108 is performed when the cell analysing 

20 unit 704 indicates that a parity error or some other error has 
been detected in a cell. 

With the described synchronizing method all 16 possible bit 
positions in a cell will have been tested as start positions 
within a cell cycle. Only the 16 bits on the positive edge of the 

25 data clock are tested. 

The cell synchronizing unit according to Fig. 12 uses both 
clock edges of the data clock from the switch port. The first bit 
of each user cell received from the switch port shall appear on 
the positive clock edge. 

30 The clock divider 814 is a 4 bit counter that is used for 

generating the different clock signals used in the switch core. 
Count up is performed on the leading edge of the data clock 
signal 718, but only if the reset signal on the reset input 832 
is not active. In the PRESYNC and SYNC states 1104/1106 and 1108, 

35 respectively, the counter 814 counts from 0 up to 15 and 
thereupon starts from 0 again. During the HUNT state 1102 the 
reset input 832 is activated. Synchronous count/reset is 
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performed on the leading edge of the data clock 718. 

The sync state machine 706 contains a two bit counter 1202, 
that on its counter input 1204 receives bit 2 from the clock 
divider 814 and keeps track of the current synchronizing state. 
5 As is also indicated in Fig. 11 00 implies HUNT state, 01 first 
PRESYNC state, 10 second PRESYNC state and 11 SYNC state. The 
four states are indicated on the output of the counter 12 02 in 
Fig. 12 with =0, =1, =2 and =3, respectively. Synchronous count 
up is performed on the rear edge of the clock signal when the 
10 count is activated by an activating input 1206 being high. 
Synchronous reset is performed on the rear edge of the clock 
signal if a reset input 12 08 is activated. 

Count up is activated when: 

- HUNT state 1202 is present and an egual signal 728 from 
15 the comparator 813 is present on the activating input 12 06, 

- PRESYNC state is present and an egual signal 728 appears 
on the activating input 1206 during the first word of a new cell. 

Reset is activated when: 

- SYNC state 1208 is present and an error indication 73 6 is 
20 optained from the cell analyser 704, 

- PRESYNC state is present and an equal signal 728 is not 
obtained from the comparator 813 during the first word of a cell. 

closer details of how to attain the functions of the sync 
state machine described above superficially, are realized by the 
25 man of the art aided by the logic blocks shown more in detail in 
Fig. 12 at 1210, 1212 and 1214 and their mutual and external 
connections, the later with reference numerals introduced from 
Fig. 7. 

The series/parallel converter 802 converts the serial bit 
30 stream to 16 bit parallel data. It consists of two 8 bit shift 
registers 806.1 and 806.2, and a 16 bit register 808. The shift 
register 806.1 is clocked on the leading edge by the bit clock 
818, the shift register 806.2 is clocked on the rear edge. The 
result will be that each of the shift registers 806.1 and 806.2 
35 are clocked every second bit cycle. This implies that when 
sixteen bits have been received the bits 1, 3 ... 15 are in the 
register 806.1 and the bits 2, 4 ... 16 in the register 806.2 
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(bit 1 is received first, bit 16 last). The first bit, i.e. bit 
1, shall be received on the positive edge of the bit clock 7 IS. 

After the sixteen bits have been received the ie bit 
register 808 is loaded. Synchronous loading is performed on the 
5 leading edge of the bit clock signal 718 on a clock input 1216 if 
the loading input 812 is activated. The loading input 812 shall 
be activated via the logic function 816 each time the clock 
divider 814 shows the value 7, or if HUNT state is present 
according to the output of the AND gate 822. 16-bit input data to 

10 the register 808 is selected from the 2x8 bits parallel output 
data from the shift registers 806.1, 806.2 in such a way that the 

bit positions 1, 3 15 are chosen from 806.1 and the bit 

positions 2, 4 ... 16 from 806.2. 

Besides the inverting input for the signal 728 from the 

15 comparator 813 and the input for the signal 726, the AND gate 822 
also has an inverting input for a user cell signal 1218 from the 
sync cell generator 744. This signal 1218 indicates that a user 
cell is being transferred to the switch port. When an error has 
arisen and a change of the HUNT state has occurred, the resynch- 

20 ronization process will not begin until the cell transmission to 
the switch port has been ended. 

The parallel/series converter 712 converts 16-bit parallel 
output data to the serial bit stream 722 towards the switch port. 
It consists of two 8-bit shift registers 712.1 and 712.2 and a 

25 multiplexor 1220. Both shift registers 712.1 and 712.2 are loaded 
at the same time by the bit clock signal 718 on clock inputs 1222 
and 1224, respectively, if loading inputs 1226 and 1228, 
respectively, from the output 828 of the clock divider 814 are 
activated. The loading input shall be activated each time the 4- 

3 0 bit counter 814 has the value 7 or 15, on its output, which 
according to the above is connected to the loading inputs 122 6 
and 1228. The bits 1, 3 ... 15 of the 16 bit parallel output data 
are loaded into 712.1, the bits 2, 4 ... 16 are loaded into 
712.2. Both shift registers 712.1 and 712.2 are clocked (shifted) 

35 on the leading edge of the bit clock 718, which implies that they 
are only shifted every second bit cycle. No shifting is performed 
if the loading input 1226 or 1228 is activated. 
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The multiplexor 1220 uses the bit clock at 12 3 0 for choosing 
between the outputs from the two shift registers 712.1 and 712.2. 
If the bit clock =1 712.1 is chosen, if the bit clock =0 712.2 is 
chosen. The result will be that after loading of the 16 bit 
5 output data, the first bit 1 will be sent to the switch port, 
thereupon bit 2, whereupon the shift registers shift data, and 
bit 3 is sent, thereupon bit 4, etc. 

The switch block 813 compares the parallel input data with 
the predetermined pattern of the first 16 bits in the synch- 
10 ronizing cell (hex'C2Fl r ) . When the pattern matches the sync 
agreement signal 828 is sent. 

The time diagrams of Figs. 13 and 14 illustrate the time 
control during the link synchronization process. 

In Fig. 13 line: 
15 1 shows the bit clock signal 718, 

2 shows output data from the register 806.1, 

3 shows output data from the register 806.2, 

4 shows the activating signal into the loading input 812 of 
the 16 bit register 808, 

20 5 shows parallel data 724 out from the register 808, 

6 shows the similarity signal 728, 

7 shows the sync state signal 74 2 from the sync state 
machine 706, 

8 shows the count signal 828 from the 4-bit counter 814, 
25 9 shows the bit-2 signal 1204 from the 4-bit counter 814 

into the counter input of the counter 12 02. 

It appears from lines 1-3 in Fig. 13 how the shift registers 
806.1 and 806.2 shift on each positive clock edge 1302 and 
negative clock edge 13 04, respectively, of the signal 718. At 

30 first the synchronization unit is in the HUNT state 1202 (Fig. 
11) , indicated at 1306 in line 7 in the diagram, and therefore 
the register 808 is loaded on each positive clock edge. Each 
clock cycle searches the parallel data 724 of the comparison 
circuit 813 for finding the synchronization pattern hex'C2Fl'. 

3 5 After some clock cycles the pattern is found, at 1308 in line 5, 
which is indicated by the equal signal 728 appearing in line 6 in 
the diagram, at 1310. The beginning of the equal signal 728 is 
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shadowed, at 1312, for indicating that some time is needed for 
making the comparison and for preventing the register 808 from 
being loaded again during the next clock cycle. The delay must be 
less than one data clock cycle. When the equal signal 728 has 
5 appeared the counter 814 starts counting, at 1314 in line 8. The 
synchronizing state PRESYNC appears, indicated at 1316 in line 7, 
when the 4-bit counter 814 has the value 7 on its output 828. 
After three consecutive sync cells transition will be performed 
to the synchronization state, as will be described below with 
10 reference to Fig. 14. 

Fig. 14 illustrates what will happen if an error in a cell 
has been detected by the cell analysing function 804. In the 
Figure there is indicated by line: 

1 the signal 812 on the loading input 1216 of the register 

15 808, 

2 the word stream 724 from the register 808, 

3 the word clock 732, i.e. bit 3 from the clock divider 814, 

4 the error signal 736 from the cell analysing function 704 
to the sync state machine 706, 

20 5 the sync state signal 742 from the sync state machine 706 

to the sync cell introduction block 708, 

6 the user cell signal 1218 from the sync cell generator 

744, 

7 the equal signal 728 from the comparison function 813. 
25 When an error in a cell has been detected by the cell 

analysing function 704, cf. line 4 at 1402, transition to the 
HUNT state appears, cf. line 5 at 1404. Due to the fact that the 
prevailing user cell signal 1218 from the sync cell generator 744 
indicates that a cell occasionally is transferred to the switch 

3 0 port, the synchronization process does not start immediately. 
First when the current user cell signal 1218 ends, indicated at 
1406 in line 6, and thereby the shift register 808 obtains the 
loading signal 812 on its loading input, indicated at 1408, 
search for synchronization is started, in line 2 this appears by 

35 the rapidly changing course at 1410 of the signal 724. In this 
case it will take 16 bit clock cycles before the equal signal 728 
indicates, at 1412 in line 7, that the pattern at 1414 in line 2 
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suits. Transition to the state PRESYNC is performed at 1416 in 
line 5. After the three consecutive equal signals 1412, 1418, 
1420 transition is performed to the synchronization state SYNC, 
at 1422, line 5. 

5 The delays by gates included in Fig. 12 are very critical 

during the synchronization process. If a data speed of 200 Mbit/s 
is used each clock period is only 10 ns long. The search for the 
synchronization pattern and the stopping of the loading ac- 
tivation signal 812 to the register 808 and the reset signal 832 
10 to the clock divider 814 must be performed during less than that 
time. 

The delay for a gate is approximately 0,3 ns. The number of 
gate levels from the input of the comparator 813 to the loading 
input 812 of the register 808 and the reset input 832 of the 

15 clock divider 814 are about 5-6, which implies less than 1,8 ns. 

The above described cell synchronization according to the 
invention is required due to the fact that the cell clock is not 
transferred. The link control could probably to a great extent be 
avoidable if a clock, that indicates start for each new cell is 

2 0 signalled over the link on both sides. It is however a desire 
that in case of a cell based switch the switch core shall be able 
to be created in one chip, where each pin however implies a cost. 
By using the above described method according to the invention, 
including that the switch core is made a clock slave, only half 

25 of the pins are required for a link. 
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Claims. 

1. A synchronizing system in a data transfer system for 
synchronizing transfer of data in the form of a bit stream (716) 
between functional entities (102,104) via a two-way link (106), 
5 each functional entity having means for applying arriving user 
data, which shall be transferred on the link, in user cells which 
can contain different number of data bits depending upon the 
magnitude of the respective data, 

characterized by a link control function (202,206) included 

10 in each functional entity with functions for starting and 
controlling the transfer of data on the link by means of sync 
cells, which are exchanged between the link control functions and 
each include, on the one hand, identification information (502) , 
by means of which the sync cell can be identified, and, on the 

15 other hand, control data (504) which by each link control 
function can be given values which admit mutual check that 
synchronism exists, or a value which in an operational state on 
the link apprehended as meaning loss of synchronism, forces the 
two link control functions to take measures to re-instate 

2 0 synchronism, said functions comprising 

an output function towards the link with a sync cell 
inserting function (708) , that receives a stream (204 t ) of user 
cells and in this introduces sync cells, and a first transforming 
function (712) , that receives the resulting stream consisting of 

25 user cells and sync cells and transforms this to a bit stream 
signal, that is clocked out with a 1-bit clock signal on the 
link, 

an input function from the link comprising a second 
transforming function (802) that receives a bit stream signal 
30 coming in from the link and translates this to an n-bit parallel 
format, that is normally clocked out for each n:th bit with an n- 
bit clock signal from the input function, 

a comparison function (813) connected for searching and 
identifying in the n-bit parallel format the identification 
35 information of a sync cell, and when it is found emit a con- 
firmation signal (728) , 

a clocking function for enabling clocking out for each bit 
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with a 1-bit clock signal of the n-bit parallel format from the 
input function, 

a sync state machine (706) , that receives the confirmation 
signal (728) for controlling the transition from clocking of the 
5 n-bit parallel format with the n-bit clock signal to clocking 
with the 1-bit clock signal. 

2. A system according to claim 1, characterized by a cell 
analysing function (704) that receives the n-bit parallel format 
and analyses and identifies user cells included therein and emits 

10 an error signal (73 6) to the sync state machine (706) when 
detecting an error of a user cell, said error signal being 
likewise used by the sync state machine (706) for said control- 
ling. 

3. A system according to claim 1 or 2, characterized in that 
15 the sync state machine has a HUNT state in which, due to lack of 

the confirmation signal (728) it emits a hunt signal (726) that 
as long as it appears provokes clocking of the n-bit parallel 
format with the 1-bit clock signal. 

4. A system according to claims 2 and 3, characterized in 
20 that the HUNT state including emission of the hunt signal also 

appears when the sync state machine receives the error signal 
(736). 

5. A system according to claim 3 or 4 , characterized by 
functionality for investigating if transmission of user cells is 

25 going on, and if this is the case emits a user cell signal 
(1218) , absence of which forming a further condition for clocking 
the n-bit parallel format with the 1-bit clock signal. 

6. A system according to claim 5, characterized by 

a first logical circuit (822) with an input for receiving 
30 the hunt signal (726) , an input for receiving the confirmation 
signal (728) , and an input for receiving the user cell signal 
(1218), and the output (824) of which takes a hunt value 
corresponding to the HUNT state when the hunt signal appears at 
lack of the confirmation signal and user cell signal, 
35 a circuit (814) for generating the n-bit clock signal, 

a second logical circuit (816) with an input connected to 
the output (824) of the first logical circuit (822) and an input 
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connected to the output of said circuit (814) for generating the 
n-bit clocking signal, and the output (812) of which is connected 
to the clocking function for forcing, when the hunt value appears 
on the output of the first logical circuit (822), the clocking 
5 function to clock the n-bit parallel format with the 1-bit clock 
signal. 

7. A system according to any of claims 1-6, characterized in 
that the input function comprises a series/parallel converter 
consisting of two parallel n/2-bit shift register (806.1,806.2), 

10 in which every second bit of the bit stream signal is clocked in 
on each its edge of the 1-bit clock signal, and the outputs of 
which are connected to the input of an n-bit register (808) , 
which has a loading input connected to the output (812) of the 
second logial circuit (816) and in which clocking in is performed 

15 with the n-bit clock signal or the 1-bit clock signal. 

8. A system according to claim 7, characterized in that the 
output function includes a parallel/series converter consisting 
of two parallel n/2-bit shift registers (712.1,712.2) in which 
every second bit of the user cell and sync cell stream is clocked 

20 in on an edge of the data clock signal, and the outputs of which 
are connected to a multiplexor (1220) controlled by the 1-bit 
clock signal, and the output (722) of which is connected to the 
link. 

9. A system according to any of claims 6-8, characterized 
25 in that the circuit for generating the n-bit clock signal 

consists of an n/4-bit clock divider (814), which has a clock 
input for receiving a 1-bit clock signal and a reset input (832) 
connected to the output (824) from the first logical circuit 
(822) . 

30 10. A system according to claims 8 and 9, characterized in 

that the output of the clock divider (814) that is connected to 
an input of the second logical circuit (816) , also is connected 
to a loading input (1226,1228) of each of the n/2-bit shift 
registers (712.1,712.2) included in the parallel/series con- 

35 verter. 

11. A system according to any of claims 3-10, characterized 
in that the state machine also has 
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a PRESYNC state which, controlled by a first control data of 
a sync cell, is started by a confirmation signal (728) having 
appeared in the HUNT state, and in which clocking of the n-bit 
parallel format is performed with the n-bit clock signal and the 
5 comparison function (813) investigates a predetermined number of 
consecutive sync cells coming in thereafter, return being 
performed to the HUNT state if the confirmation signal lacks 
before the predetermined number of sync cells have been in- 
vestigated, and 

10 a SYNC state which, as controlled by a second control data 

of a sync cell, is started by a confirmation signal (728) having 
been received in the PRESYNC state for all of the predetermined 
number of sync cells, and in which transmission of data on the 
link is admitted while supervising data with respect to errors, 

15 transition to the HUNT state being performed if an error is 
found. 

12. A method for synchronizing, in a cell based switch, 
transmission of user cells which can contain different numbers of 
data bits, between switch ports and a switch core via a two-way 

20 link, characterized in that the transmission of data on the link 
is started and supervised by means of sync cells which are 
exchanged between the functional entities and each contains, on 
the one hand a synchronizing pattern, by means of which the sync 
cell can be identified, and, on the other hand, control data 

25 which by the functional entitites can be set to values admitting 
mutual checking that synchronism prevails, or a value that in a 
state of operation on the link is apprehended as implying loss of 
synchronism, forces the functional entities to take measures for 
reinstating synchronism. 

30 13. A method according to claim 12, characterized in that 

starting of two-way transmission of data is preceded by the 
functional entities sending a predetermined number of consecutive 
sync cells to each other, the control data of which imply a 
request for return of a sync cell, the control data of which has 

35 a value confirming presence of synchronism. 

14. A method according to claim 13, characterized in that 
the transmission of data is started after each of the functional 
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entities has responded to the last of the respective predetermi- 
ned number of sync cells by sending the desired sync cell in 
return . 

15. A method according to any of claims 12-14, characterized 
5 in that the mutual check of synchronism being present is 
performed by the functional entities regularly sending sync cells 
to each other, the control data of which implying a request for 
return of a sync cell, the control data of which has a value 
confirming presence of synchronism. 

10 16. A method according to any of claims 12-15, characterized 

in that the value forcing the functional entities to take 
measures for reinstating synchronism is included in a predetermi- 
ned number of sync cells being sent by the functional entity that 
has detected loss of synchronism and means a request for return 

15 of a sync cell the control data of which has a value confirming 
presence of synchronism. 

17. A method according to any of claims 12-15, characterized 
in that the value forcing the functional entities to take 
measures for reinstating synchronism, is included in a predeter- 

2 0 mined number of sync cells being sent by the functional entity 
having detected loss of synchronism and involves a request to the 
other functional entity to break transmission of data and send a 
sync cell the control data of which has a value confirming 
presence of synchronism. 

25 18. A method according to claim 16 or 17, characterized in 

that the transmission of data is started newly from the func- 
tional entity having detected loss of synchronism, after the 
second functional entity having answered to the last of the 
predetermined number of sync cells by sending the desired sync 

30 cell in return. 

19. A system for synchronizing, in a cell based switch, 
transmission of user cells which can contain different numbers of 
data bits, between functional entities via a two-way link, 
characterized by a link control function included in each 

35 functional entity containing functions for starting and control- 
ling the transmission of data on the link by means of sync cells 
which are exchanged between the link control functions controlled 
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by a sync state machine that has three states, viz. 

a HUNT state in which the link control function is brought 
to investigate a sync cell coming in from the link for determi- 
ning whether it agrees to a predetermined pattern for sync cells, 
5 a PRESYNC state which, in the HUNT state, is preceded by a 

sync cell being in agreement with the predetermined pattern, 
having been found, and in which the link control function is 
brought to investigate a predetermined number of consecutive sync 
cells coming in thereafter for determining whether they agree to 

10 the predetermined pattern, return to the HUNT state being 
performed if this is not the case, 

a SYNC state being preceded, in the PRESYNC state, by the 
predetermined number of sync cells showing agreement with the 
predetermined pattern, and in which transfer of data on the link 

15 is admitted while supervising data with respect to errors, 
transition of the HUNT state being performed if an error is 
found . 

20. A system according to claim 19, characterized in that 
each sync cell includes, on the one hand, a synchronizing 

2 0 pattern, by means of which the sync cell can be identified, and 
on the other hand, control data that by the link control function 
can be given values admitting mutual checking between the link 
control functions that synchronism is present, or a value that in 
a state of operation on the link apprehended as implying loss of 

25 synchronism, forces the link control functions to take measures 
for reinstating synchronism. 

21. A system according to claim 20, characterized in that 
the link control function in the functional entity originating 
data receives the following control data in sync cells from the 

30 link control function in the receiving functional entity, viz. 

a first control data implying instruction to break a current 
transfer of data and instead send a sync cell, and end a current 
sync cell transfer for thereafter inserting the new sync cell, 
a second control data indicating that the state SYNC is 
35 present and implying that a sync cell shall be sent in return at 
a first suitable point of time in the normal cell flow so as to 
provoke as little disturbance as possible during normal opera- 
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tion, 

a third control data indicating that no sync cell is 
required in return. 

22. A system according to claim 21, characterized in that in 
5 the states HUNT and PRE SYNC of the state machine a link control 

function sends sync cells to the second link control function 
containing the first or second control data at the first suitable 
point of time without stopping the current cell transmission. 

23. A system according to claim 21 or 22, characterized in 
10 that in the state SYNC of the state machine a link control 

function sends data to the other link control function or reacts 
on incoming sync cells including the first or second control 
data. 
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